Template-based remote/local file selection techniques for  modular backup and migration

ABSTRACT

File selection techniques that can handle overlapping module contexts provide flexible and reversible backup, restore, migration, deployment and synchronization operations. Both remote (administrative) control and local (user) control of the file selection are provided. Application and configuration specific templates are provided to a user from the remote administrator for further customization by selecting or de-selecting configurations, applications and/or individual files or configuration entries. The templates may be controlled geographically by the IP address or identity associated with the user. A user&#39;s interaction with the customization is saved and the order of changes is maintained, so that when the templates are updated, the user&#39;s customizations can be re-applied. The administrator may override user settings based on rules, which may also be geographically determined. The file selection may also be altered based on media type and location, e.g., local backup vs. server backup.

The present application is a Continuation of U.S. patent application Ser. No. 12/044,188, filed on Mar. 7, 2008 and claims priority thereto under 35 U.S.C. §120. The disclosure of the above-referenced parent U.S. patent application is incorporated herein by reference.

BACKGROUND OF THE INVENTION

1. Field of the Invention

The present invention is related to computer management software, and more particularly to template-based file selection techniques providing remote/local file selection for modular backup and migration.

2. Description of Related Art

Application and operating system backup and migration tools, as well as other tools such as synchronization mechanisms provide file selection interfaces for selecting sets of files and configuration entries for backup, restore, synchronization, deployment and migration of applications and system components. On a workstation level, a user or administrator typically selects or de-selects directory tree levels and/or individual files to include in a backup, migration or synchronization session. The configuration is typically saved at the location of the backup program, whether located at a central local-area network backup point, or on the individual workstation. More recent systems have the ability to backup/migrate configuration information such as configuration files and registry entries. Upon restore, backup algorithms generally offer the option to deselect files that are contained in a backup, so that some files contained on the back are not over-written.

Applications generally have large numbers of files and configuration entries that make it difficult for a user or administrator to select just the files associated with an application. Further, the particular files and the names of files associated with an application typically varies from version to version of an application. It would be desirable for an administrator or end user to easily select files associated with an application, in order to accomplish the above-listed tasks without having to generate a list of files themselves, which in some cases is a tedious and time-consuming task requiring a high level of skill and often a large amount of trial-and-error or sophisticated analysis. Further, the typical backup or system configuration strategy is either controlled by an administrator or the local user, but not both, even though it would be desirable to provide end-user controlled file selection while receiving some automatic protection and assistance from the administrative level.

Further, present administrative backup and deployment systems typically have a uniform behavior with respect to workstation backup and deployment of software, while differing geographical or user needs may dictate differences requiring adjustment for individual workstations or users. Also, depending on the destination of a backup, certain files may be desirable for backup, while other may not be, such as when a large number or large-sized personal files of a user are present on a system and backup is not needed for ensuring continuity of business operations. In such circumstances, it would be desirable to provide the user a flexible and friendly backup environment, while ensuring that such files do not waste valuable server resources.

BRIEF SUMMARY OF THE INVENTION

The invention is embodied in a computer-performed method, computer program product and computer system that provides file selection for backup, deployment, migration, restore and synchronization based on application-associated templates. Upon starting a backup, deployment, migration, restore or synchronization task, or upon generating an initial profile to be used repeatedly for such a task, the user is presented with a selection between pre-configured modules that can be selected or de-selected from templates to provide a file selection profile. The modules may be application level modules, or full configuration modules representing one of a number of pre-determined configurations that generally include multiple applications. The user may further customize the file selection not only by selecting/de-selecting configuration(s) and/or applications, but by selecting and de-selecting individual file tree levels/directories and files, along with individual configuration entries to generate a user/workstation specific file selection profile.

Multi-point and updateable file selection management can be provided by storing a user's customization of the file selection, including an order of customization operation, so that when an administrative update is made to the configuration, application or other selection templates, the customization can be applied to the updated templates to generate a new file selection profile. The templates are generally provided as feeds to the various workstations, and particular feed selection may be made based on geographic criteria, which may be IP address-based and/or user-based.

The file selection engine and file copying engine is provided also as a feed-delivered object, which may be a JAVA object (JAVA is a trademark of Sun Microsystems, Inc.) or other deliverable executable/interpretable engine. The file copying engine may be perform differently depending on the destination/source of the files, e.g., if the destination/source is a backup server, certain files may be excluded from the backup or vice-versa, whereas if the destination/source is local media, a different filter criteria (or no filtering) may be employed.

The foregoing and other objectives, features, and advantages of the invention will be apparent from the following, more particular, description of the preferred embodiment of the invention, as illustrated in the accompanying drawings.

BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING

The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself, however, as well as a preferred mode of use, further objectives, and advantages thereof, will best be understood by reference to the following detailed description of the invention when read in conjunction with the accompanying Figures, wherein like reference numerals indicate like components, and:

FIG. 1 is a block diagram illustrating a networked computer system in which techniques according to an embodiment of the present invention are practiced.

FIG. 2 is an organizational and flow diagram of a file selection and transfer process within the system of FIG. 1.

FIG. 3 is an organizational and flow diagram of a template update process within the system of FIG. 1.

FIG. 4 is a pictorial diagram depicting a property page of a user interface for controlling a template and application selection process in accordance with an embodiment of the present invention.

FIG. 5 is a flow chart of a file selection method in accordance with an embodiment of the present invention.

FIG. 6 is a flow chart of a template update method in accordance with an embodiment of the present invention.

DETAILED DESCRIPTION OF THE INVENTION

The present invention relates to file selection techniques that are applied to backup, migration, synchronization, deployment and other forms of file transfer between systems. The file selection techniques of the present invention provide for pre-defined templates that generally combine sets of files and configuration entries associated by application, but also provide for user-defined templates that combine the sets of application-associated files without requiring use of a pre-defined template. The user is permitted to modify the file selection specified by the template or user-defined set of application files, by selecting or de-selecting individual directories or files in addition to, or to be removed from the file selection specified by the template. The user may also specify particular file types (e.g., by MIME type or extension) for inclusion in or exclusion from the backup. The geographic location of the workstation, IP address, user identity, user group membership, workstation identity or other identifier associated with a user or the workstation may be used to determine one or more templates fed to the a workstation via an RSS feed or other transfer mechanism. The user's interaction with or definition of the current template is stored as a set of changes, which are ordered according to the order of entry. As templates are updated, which is generally accomplished by a differential update object, the stored changes are applied to the updated template, so that user-customization is preserved. Both attended and unattended backups and other processes may be supported by the techniques of the present invention, with the last version of a customized template used when performing automatic backups or other transfers.

Administrative override rules, which are also generally provided by an RSS feed or other transfer mechanism, may be applied to the final list of files selected by the above-described process to force the inclusion or exclusion of specific file, directories and/or file types. The specific administrative override rules applied may also be selected according to the geographic location of the workstation, IP address, user identity, user group membership, workstation identity or other identifier associated with a user or the workstation and may also be varied or omitted depending on the destination of the file transfer. For example, if a user is generating a local backup to removable media, user selection or de-selection of any file for backup may be permitted, whereas certain file types or specific files and directories may be omitted from the file list according to administrative rules if the backup destination is remote storage managed by a server in order to reduce storage and bandwidth requirements, and to meet internal administrative standards. Certain file types and/or directories may also be required in the file transfer list if the backup destination is remote storage, so that a minimum level of accepted backup is maintained. The user may be presented with a final list of selected files and directories as modified by the administrative rules, as a display or user-interface inviting further modification, or the application of administrative overrides may be automatic and the resultant file/directory list might not be displayed to the user.

Referring now to FIG. 1, a networked computer system in which an embodiment of the present invention is practiced is depicted in a block diagram. An administrative server 20 includes a server processor SCPU coupled to a server memory SMEM that contains program instructions for implementing a portion of a system in accordance with an embodiment of the present invention and forming a computer-program product in accordance with another embodiment of the present invention. Administrative server 20 is coupled to a number of workstation computers 10, which in the depicted embodiment each include a workstation processor CPU coupled to a workstation memory MEM that contains program instructions for implementing another portion of the system and forming a computer-program product in accordance with another embodiment of the present invention. Workstation computers 10 are also depicted as including a graphical display Display and input devices Input Devices, such as mice and keyboards, for interacting with a user interface as described in further detail below. Workstation computers 10 are coupled to administrative server 20 over network, which may include wireless local area networks (WLANs), wired local-area networks (LANs), wide-area networks (WANs) or any other suitable interconnection that provides communication between administrative server 20 and workstation computers 10. Further, the present invention concerns file selection and transfer techniques that are not limited to a specific computer system configuration or requiring a network at all, as some embodiments of the present invention are applicable to individual computer systems, and the network-informed embodiments of the present invention retain some functionality even in off-line configurations, such as when generating a local backup at a workstation 10 based on templates provided from administrative server 20. Finally, the specification of an administrative server 20 and workstation 10 and the location of their specific memories MEM and SMEM does not imply a specific client-server relationship or hierarchical organization, as the techniques of the present invention may be employed in distributed systems in which the administrative role, if employed at all, is defined by an identity and control privilege, rather than by association with a particular location or hardware type.

Referring now to FIG. 2, an organization and information flow within the system of FIG. 1 is illustrated. Administrative server 20 includes a template database 22 from which template objects are transferred to workstation computer 10 via RSS feeds or another transfer technique. The specific template object or objects provided to workstation computer 10 may be determined in conformity with the geographic location of the workstation, IP address, user identity, user group membership, workstation identity or other identifier associated with a user or workstation computer 10. Alternatively, all template objects may be made available for user-selection, or all template objects may be downloaded and selection made by user identity determined by the user's login profile, group membership or privilege level. The template objects also include application definitions, from which the template objects build file selection profiles, as the template objects generally specify collections of applications and other files, and the application file and configuration entry selections are more easily maintained as separate objects. One of the template objects is selected either by one of the above-described identification processes, or by the user via input provided to a user interface. A “blank” template is also provided for generating a user-defined template. The user is provided with control of the selection of applications included in the template, modification of the directories and files selected by the template via a tree control or other mechanism, selection/de-selection of particular file types by MIME type or file extension. The user is also provided with the ability to search for files for selection, such as by text string, filenames with wildcards, and other file search mechanisms as commonly known in the art. While objects are used in the exemplary embodiment to implement templates and other features such as application definitions, it is not necessary to use object-oriented programming to implement any of the techniques of the present invention. Templates, application definitions and other features of the present invention such as administrative overrides can alternatively be provided as XML files containing data fields or rules that may or may not be associated with methods. Further the above-mentioned data structures may be provided as simple textual or binary data files or database objects which are read and operated on using separately packaged program code.

Any user input that modifies the template is applied to the template to generate a local template copy 13, which is used along with the associated selected application definitions 11 to generate a profile 16 that specifies the files to transfer. Application definitions 11 are also objects provided by and maintained via feeds from administrative server 20, but as described above, application definitions 11 may be implemented as other forms of data. The user input is also recorded to a template change record 14, which provides local storage of the manner and order in which the user applied modifications to a pre-defined template or defined a user-defined template. Template change record 14 is used to preserve user-customization of the file selection, so that when templates are updated, the user's changes can be reapplied as described in further detail below. Once profile 16 is built, administrative overrides, which are supplied as RSS feeds from administrative server 20 are applied to a filter process 18 that changes the file selection in accordance with administrative requirements. While RSS feeds are used in the exemplary embodiment to transfer objects and data between workstation computers 10 from administrative processes, other feed techniques or transfer techniques may be employed, including local software installation from distribution media. While objects are used in the exemplary embodiment to implement templates and other features such as application definitions, it is not necessary to use object-oriented programming to implement any of the techniques of the present invention. Templates, application definitions and other features of the present invention such as administrative overrides can alternatively be provided as XML files containing data fields or rules that may or may not be associated with methods. Further the above-mentioned data structures may be provided as simple textual or binary data files or database objects which are read and operated on using separately packaged program code. Filter process 18 may also be responsive to the destination of the file transfer as described above. Illustrated transfer destinations are remote storage 24 managed by administrative server 20 or local removable storage 12, which may be a USB FLASH drive, recordable optical media or other storage type. Other storage locations may be managed by the present invention and the illustrated storage options are exemplary only, and are not intended to limit the types or location of storage that may be employed in embodiments of the present invention. Once the selected files and configuration entries are determined, the actual files and configurations are transferred to their destination, e.g., local removable storage 12 or remote storage 24.

Referring now to FIG. 3, another organization and information flow within the system of FIG. 1 is illustrated. When a template and/or application definition is updated, a differential update object is fed from administrative server 20 to workstation computer 10. If the update includes only application definition objects, application definitions 11 are overwritten with the updated versions. However, when a template object is updated (to add/remove applications or specific directories or files), then the latest template change record 14 is retrieved and applied in the stored order of user entry, to modify the updated template. The resulting template is stored as local template copy 13. Changes from template change record are applied after the differential update to the corresponding template object is accomplished. The template objects and application definitions described above are implemented as XML (extensible markup language) objects, so that generation of rules and differential updates are easily effected. However, other types of data/program code implementations are usable to implement the same functionality, and are contemplated as alternatives that fall within the scope of the present invention.

Referring now to FIG. 4, a user interface screen for providing user input to controlling a template and application selection process in accordance with an embodiment of the invention is shown. The depicted display shows a set of property pages, with the active page displaying an application and template selection page. Other property pages include the above-described file/folder selection, file type selection and search user inputs, which are implemented as known in the art. However, in order to control the file selection process of the present invention, it is necessary to provide for additional user input. Such user input is provided by a template selection menu 34, from which predetermined templates are selectable. Generally, a single template is selected for each workstation, but multiple template embodiments are possible, with merger of modular application group selections, for example. A “user_defined” option is selected, in which no applications or other files/configuration items are initially selected (or a mandatory base configuration can be used as an alternative to a “blank” template). The selectable templates may be restricted by the geographical or other workstation/user identifiers as described above, which may be effected by displaying only a set of template objects that were downloaded to the corresponding workstation based on workstation/user identification. Template selection menu 34 may be omitted if template selection is made automatically, e.g., in implementations where a single template is downloaded per workstation. A user-defined template option can then be selected with a single checkbox that disables/enables use of the predetermined template.

An application selection menu 36 provides for either modification of a pre-selected set of applications specified by the selected predetermined template (or the modified local template after the user input has modified the template) or generation of a user-defined template, which will generally start with no applications selected. Although selection of an entry in application selection menu 36 will specify certain files for backup or other file transfer, the user may modify the set of files using the other available property page tabs, as well as by selecting particular other folders specified in predetermined template folders fields 32. The folders/directory paths specified in template folders fields 32 are generally common paths for backup/migration/synchronization for any user, such as the default documents folder and the desktop folder. An “ADD” and/or “REMOVE” button can be included to change the template folders fields 32, but since other folder paths can be included in the file selection via the “All Files and Folders” property sheet, and the predetermined template folders fields 32 can be de-selected, such functionality is not needed on the template and application selection page. Therefore, in the depicted embodiment, the folders specified by the selected predetermined template are shown as static members.

Referring now to FIG. 5, a file selection method in accordance with an embodiment of the present invention is depicted in a flowchart. First, the workstation is scanned to obtain a file index (step 40) and a user interface is presented showing the predefined template and application selection options (step 41). If the user changes the template or application selections (step 42), then the local template is changed (step 43). Next, directories and then files are selected according to the current local template (step 44). In each of the above described file and directory selection modification techniques, consistency must be maintained with respect to application of directory and file selection order. In particular, selection of directories is performed first, with selection/de-selection of individual files performed second. Since selection/de-selection of a directory potentially impacts the selection status of all of the files in the directory, the directory operation must be performed first to avoid undoing individual file selections/de-selections. Next a user interface is displayed showing selected directories and files according to the current local template (step 45). While step 45 is described in a linear sense with respect to the flowchart, it is understood that the user may be required to activate a particular property page or menu item, such as the “All Files and Folders” property tab of FIG. 4, in order to view the actual files and folders selected by the local template. Therefore, if a user wishes only to select particular applications, or to apply a particular or default template without modifying files or directory paths specified thereby, it is not necessary to interact with the file/folder selection/de-selection interface at all.

Next, if the user modifies the selections (decision 46) the local template is further modified and the file list is also modified removing entries that were de-selected and searching for entries added by the user modifications (step 47). At this point user changes to the template are stored in a cumulative ordered list, so that the user-customization is preserved for application to later updated templates (step 48). Next, any administrative overrides (decision 49) are applied to the file list (step 50), and as mentioned above, administrative overrides can be conditionally applied based on workstation/user identifiers and/or the destination or media type of the file transfer. Finally, the final selections may be displayed and the user may be prompted to make any further changes, or the transfer may proceed without user intervention (step 51).

Referring now to FIG. 6, a template update method in accordance with an embodiment of the present invention is depicted in a flowchart. When a template update is received (step 60), the update is applied to a local copy of the predetermined template (step 61). (The local copy of the predetermined template is not the user-modified local template, but the predefined starting-point template.) If stored user changes are present for the template (step 62), then the local copy of the template, i.e., the user-modified template, is generated by applying the stored changes to the updated template from step 61 in the original order in which the user made the changes to the predetermined template prior to the update (step 63). As mentioned above, preserving the order is necessary to ensure consistent results in applying the stored user input.

While the invention has been particularly shown and described with reference to the preferred embodiments thereof, it will be understood by those skilled in the art that the foregoing and other changes in form, and details may be made therein without departing from the spirit and scope of the invention. 

What is claimed is:
 1. A computer-performed method for selecting files and/or configuration entries for backup, migration, restoration or synchronization comprising: during a backup, migration or synchronization session, first reading a first template specifying one or more applications, wherein a corresponding at least one first collection of files is specified for each of the one or more applications, wherein each of the at least one first collection of files is specified for transfer between a workstation and a storage location; during the backup, migration or synchronization session, presenting a user interface to a user, wherein the user interface accepts a sequence of commands from the user, wherein application of the commands modifies the template read by the first reading to produce a first local template specifying at least one first modified collection of files; storing the first local template specifying the at least one first modified collection of files; storing an ordered record of the sequence of commands accepted by the user interface; during the backup, migration or synchronization session first transferring the at least one first modified collection of files between the workstation and the storage location in conformity with the stored first local template; during a subsequent backup, migration or synchronization session, second reading a second template specifying at least one second collection of files for transfer, wherein the second template differs from the first template; during the subsequent backup, migration or synchronization session, third reading the stored ordered record of the sequence of commands; during the subsequent backup, migration or synchronization session, modifying the second template using the sequence of commands retrieved by the third reading by applying the sequence of commands in sequential order to the second template to produce at least one second local template; and during the subsequent backup, migration or synchronization session, second transferring files specified by the at least one second local template between the workstation and the storage location in conformity with the second local template.
 2. The computer-performed method of claim 1, further comprising transferring the second template to the workstation from an administrative server as an updated version of the first template.
 3. The computer-performed method of claim 2, further comprising selecting the second template in conformity with identifying information associated with the workstation or a user providing the user input, and wherein the transferring transfers the selected template to the workstation from a server.
 4. The computer-performed method of claim 2, further comprising: receiving an object specifying an administrative override at the workstation, wherein the administrative override contains rules for modifying the at least one first collection of files independent of and superseding the sequence of commands accepted from the user, whereby at least one file specified by the sequence of commands is excluded from or included in the first modified collection of files in accordance with the administrative override; and altering the first modified collection of files according to the administrative override prior to the first transferring, whereby the first transferring is performed in further conformity with exclusions or inclusions in the first modified collection of files according to the administrative override.
 5. The computer-performed method of claim 1, further comprising automatically detecting a media type or location of the storage location, and responsive to the automatically detecting, selectively including files in or excluding files from the first modified collection of files used by the first transferring in conformity with the detected media type or location of the storage location.
 6. The computer-performed method of claim 4, wherein the rules contained in the administrative override selectively include and exclude files from the first modified collection of files according to a geographic location of the workstation and a media type of the storage location, and wherein the altering alters the first modified collection of files by selectively applying the rules contained in the administrative override according to the geographic location of the workstation and the media type of the storage location.
 7. A computer system comprising: a processor, a computer-readable memory and a computer-readable, tangible storage device; program instructions, stored on the storage device for execution by the processor via the memory, to, during a backup, migration or synchronization session, first read a first template specifying one or more applications, wherein a corresponding at least one first collection of files is specified for each of the one or more applications, wherein each of the at least one first collection of files is specified for transfer between a workstation and a storage location; program instructions, stored on the storage device for execution by the processor via the memory, to, during the backup, migration or synchronization session, present a user interface to a user, wherein the user interface accepts a sequence of commands from the user, wherein application of the commands modifies the first template read by the program instructions that read the first template to produce a first local template specifying at least one first modified collection of files; program instructions, stored on the storage device for execution by the processor via the memory, to store the first local template specifying the at least one first modified collection of files; program instructions, stored on the storage device for execution by the processor via the memory, to store an ordered record of the sequence of commands accepted by the user interface; program instructions, stored on the storage device for execution by the processor via the memory, to, during the backup, migration or synchronization session, first transfer the at least one first modified collection of files between the workstation and the storage location in conformity with the stored first local template; program instructions, stored on the storage device for execution by the processor via the memory, to, during a subsequent backup, migration or synchronization session, second read a second template specifying at least one second collection of files for transfer, wherein the second template differs from the first template; program instructions, stored on the storage device for execution by the processor via the memory, to, during the subsequent backup, migration or synchronization session, third read the stored ordered record of the sequence of commands; program instructions, stored on the storage device for execution by the processor via the memory, to, during the subsequent backup, migration or synchronization session, modify the second template using the sequence of commands retrieved by program instructions that third read the stored ordered record by applying the sequence of commands in sequential order to the second template to produce at least one second local template; and program instructions, stored on the storage device for execution by the processor via the memory, to, during the subsequent backup, migration or synchronization session, second transfer files specified by the at least one second local template between the workstation and the storage location in conformity with the second local template.
 8. The computer system of claim 7, further comprising an administrative server coupled to the processor, wherein the administrative server includes a server processor, a server memory for storing server program instructions for execution by the server processor, wherein the server program instructions comprise program instructions that transfer the second template to the workstation from an administrative server as an updated version of the first template.
 9. The computer system of claim 8, wherein the server program instructions further comprise program instructions that select the second template in conformity with identifying information associated with the workstation or a user providing the user input, and wherein the server program instructions that transfer the template transfer the selected template to the workstation from a server.
 10. The computer system of claim 8, wherein the program instructions further comprise program instructions that, when executed by the processor, receive an object specifying an administrative override, wherein the administrative override contains rules for modifying the at least one first collection of files independent of and superseding the sequence of commands accepted from the user, whereby at least one file specified by the sequence of commands received by the program instructions is excluded from or included in the first modified collection of files in accordance with the administrative override, wherein the program instructions alter the first modified collection of files according to the administrative override prior to the first transferring, whereby the program instructions that first transfer the files perform the transferring in further conformity with exclusions or inclusions in the first modified collection of files according to the administrative override.
 11. The computer system of claim 7, wherein the program instructions further comprise program instructions, that, when executed by the processor: automatically detect a media type or location of the storage location; and selectively include files in or exclude files from the first modified collection of files used by the program instructions that first transfer the files, in conformity with the automatically detected media type or location of the storage location.
 12. The computer system of claim 10, wherein the rules contained in the administrative override selectively include and exclude files from the first modified collection of files according to a geographic location of the workstation and a media type of the storage location, and wherein the program instructions alter the first modified collection of files by selectively applying the rules contained in the administrative override according to the geographic location of the workstation and the media type of the storage location.
 13. A computer program product comprising computer-readable, tangible storage device and computer-readable program instructions stored on the computer-readable tangible storage device to select files and/or configuration entries for backup, migration, restoration or synchronization, the program instructions, when executed by a processor: during a backup, migration or synchronization session, first read a first template specifying one or more applications, wherein a corresponding at least one first collection of files is specified for each of the one or more applications, wherein each of the at least one first collection of files is specified for transfer between a workstation and a storage location; during the backup, migration or synchronization session, present a user interface to a user, wherein the user interface accepts a sequence of commands from the user, wherein application of the commands modifies the template read by the program instructions that read the first template to produce a first local template that specifies at least one first modified collection of files; store the first local template that specifies the at least one first modified collection of files; store an ordered record of the sequence of commands accepted by the user interface; during the backup, migration or synchronization session first transfer the at least one first modified collection of files between the workstation and the storage location in conformity with the stored first local template; during a subsequent backup, migration or synchronization session second read a second template specifying at least one second collection of files for transfer, wherein the second template differs from the first template; during the subsequent backup, migration or synchronization session, third read the stored ordered record of the sequence of commands; during the subsequent backup, migration or synchronization session, modify the second template using the sequence of commands retrieved by program instructions that third read the stored ordered record by applying the sequence of commands in sequential order to the second template to produce at least one second local; and during the subsequent backup, migration or synchronization session, second transfer files specified by the at least one second local template between the workstation and the storage location in conformity with the second local template.
 14. The computer program product of claim 13, wherein the program instructions further comprise program instructions that, when executed by the processor, receive the second template from an administrative server as an updated version of the first template.
 15. The computer program product of claim 14, wherein the program instructions further comprise program instructions, that, when executed by the processor receive an object specifying an administrative override, wherein the administrative override contains rules for modifying the at least one first collection of files independent of and superseding the sequence of commands accepted from the user, whereby at least one file specified by the sequence of commands received by the program instructions is excluded from or included in the first modified collection of files in accordance with the administrative override, wherein the program instructions alter the first modified collection of files according to the administrative override prior to the first transferring, whereby the program instructions that first transfer the files perform the first transfer in further conformity with exclusions or inclusions in the first modified collection of files according to the administrative override.
 16. The computer program product of claim 13, wherein the program instructions further comprise program instructions, that , when executed by the processor: automatically detect a media type or location of the storage location; and selectively include files in or exclude files from the modified collection of files used by the program instructions that first transfer the files, in conformity with the automatically detected media type or location of the storage location.
 17. The computer program product of claim 15, wherein the rules contained in the administrative override selectively include and exclude files from the first modified collection of files according to a geographic location of the workstation and a media type of the storage location, and wherein the program instructions alter the first modified collection of files by selectively applying the rules contained in the administrative override according to the geographic location of the workstation and the media type of the storage location.
 18. A computer program product comprising a computer-readable, tangible storage device and computer-readable program instructions stored on the computer-readable, tangible storage device to select files and/or configuration entries for backup, migration, restoration or synchronization, the computer-readable program instructions, when executed by a processor: read a template specifying one or more applications, wherein a corresponding at least one collection of files is specified for each of the one or more applications, wherein each of the at least one collection of files is specified for transfer between a workstation and a storage location; present a user interface to a user, wherein the user interface accepts a sequence of commands from the user, wherein application of the commands modifies the template read by the program instructions that read the template to produce a local template specifying at least one modified collection of files; store the local template specifying the at least one modified collection of files; receive an object specifying an administrative override at the workstation, wherein the administrative override contains rules for modifying the at least one collection of files independent of and superseding the sequence of commands accepted from the user, whereby at least one file specified by the sequence of commands is excluded from or included in the modified collection of files in accordance with the administrative override; alter the modified collection of files according to the administrative override to make exclusions from or inclusions in the modified collection of files according to the administrative override; and transfer the at least one modified collection of files between the workstation and the storage location in conformity with the stored local template and the exclusions from or inclusions in the modified collection of files specified by the administrative override.
 19. The computer program product of claim 18, wherein the rules contained in the administrative override selectively include and exclude files from the first modified collection of files according to a geographic location of the workstation and a media type of the storage location, and wherein the program instructions alter the first modified collection of files by selectively applying the rules contained in the administrative override according to the geographic location of the workstation and the media type of the storage location.
 20. A computer-performed method for selecting files and/or configuration entries for backup, migration, restoration or synchronization comprising: reading a template specifying one or more applications, wherein a corresponding at least one collection of files is specified for each of the one or more applications, wherein each of the at least one collection of files is specified for transfer between a workstation and a storage location; presenting a user interface to a user, wherein the user interface accepts a sequence of commands from the user, wherein application of the commands modifies the template read by the program instructions that read the template to produce a local template specifying at least one modified collection of files; storing the local template specifying the at least one modified collection of files; receiving an object specifying an administrative override at the workstation, whereby at least one file specified by the sequence of commands is excluded from or included in the modified collection of files in accordance with the administrative override; altering the modified collection of files according to the administrative override to make exclusions from or inclusions in the modified collection of files according to the administrative override; and transferring the at least one modified collection of files between the workstation and the storage location in conformity with the stored local template and the exclusions from or inclusions in the modified collection of files specified by the administrative override.
 21. The computer-performed method of claim 20, wherein the rules contained in the administrative override selectively include and exclude files from the first modified collection of files according to a geographic location of the workstation and a media type of the storage location, and wherein the altering alters the first modified collection of files by selectively applying the rules contained in the administrative override according to the geographic location of the workstation and the media type of the storage location. 